What is claimed is: 
[Claim 1] (currently amended) A system for evaluating a set of rules, the system 
comDrisina: a rule engine implementing the RETE algorithm with novel extensions capable 
of distributing patterns to one or more systems, a set of rules defined bv an user, and a set 
of data provided bv the user A rule cnoine wh i ch i mp l cmonts the RETE a l gor i thm w i th novel 
QxtGnsions. which support d i str i buted pattern matching . 

[Claim 2] (currently amended) A system according to claim 1 wherein the system converts 
an object structure to an internal structure, which the rule engine uses to perform 
operations and reason over dat a into un ordGrcd facts w i thin the cnqinQ . 
[Claim 3] (currently amended) A system according to claim 1 wherein the system stores 
data in a database called working memory: which may span multiple partitions across 
several computer systems and is capable of distributing indexes across multiple rule 
engines implements the notion of work i ng memory as dGScribod i n roforonco artic l e 1 ■ 
[Claim 4] (currently amended) A system according to claim 1 wherein the system creates 
input nodes for each class type and is capable of propagating data through a local network, 
or remotely to a rule engine running on a separate computer system Input nodes as defined 
i n reference article 1 are extended with the capab i l i ty to route objects to a remote rule 
engine or use it locally . 

[Claim 5] (currently amended) A system according to claim 1 wherein the system uses a 2 
input loin node to evaluate 2 or more data elements and determines if the data should 
propagate further through the network on a separate system or locall y loin nodes as def i ned 
in reference article 1 arc extended with the capability to route matched patterns local l y or 
remote l y . 

[Claim 6] (currently amended) A system according to claim 1 wherein the system uses a 

Terminal nodes to indicate all the conditions of a rule have been met and is a candidate for 
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immediate or delayed execution locally or on a remote computer system Terminal nodes as 
defined in reforonco artic l e 1 are extended with the capability to route matched patterns 
l oca ll y or remote l y . 

[Claim 7] (currently amended) A pattern for a given class type temp l ate according to 
claim 2 uses a linear sequence of nodes representing the patterns to match for the class 
type: these nodes are called intra-element nodes an obioct , 
[Claim 8] (currently amended) A system according to claim 1 wherein the system 
implements a component an abstraction lay e r for retrieving remote facts residing in a 
separate rule engine process , 

[Claim 9] (currently amended) A system according to claim 1 wherein the system uses a 
call back mechanism between the working memory, the rule engine and the objects; which 
objects use to notify the rule engine of changes. 

[Claim 10] (currently amended) A system according to claim 1 wherein the system 
requires object instantiations to implement a base defined interface for the call back 
mechanism, which may be added to the classes using byte code manipulation . 
[Claim 1 1 ] (currently amended) A system according to claim 1 wherein the system 
monitors the resource usage; which is used to determine when RETE nodes are distribute to 
other rule engines . 

[Claim 1 2] (currently amended) A system according to claim 1 wherein the system uses 
rules to manage the distribution of nodes to remote systems. 
[Claim 1 3] (currently amended) A system according to claim 1 wherein the system 
distributes pattern matching by serializing copying the nodes and sending them to a remote 
system; which are then added to remote engine's network . 

[Claim 1 4] (currently amended) A system according to claim 1 wherein the system 
distributes the class type node wmrt. 2 input node 4em. terminal node and intra-element 
nodes to a remote system. 
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[Claim 1 5] (original) Distributed nodes according to claim 14 maintains a list of remote 

systems which depend on the indexes produced by pattern matching. 

[Claim 16] (currently amended) A system according to claim 1 wherein the system w ill 

scr i a li zG transmit the values of an object to a remote system^ if the corresponding pattern 

matches against a remote object pattern , or it mav perform join using the indexes directly . 

[Claim 17] (currently amended) A system according to claim 1 wherein the system mav 

serialize the data object and its values to a remote system^ if the object contains procedural 

logic and functional attachments includ i ng romote service method calls . 

[Claim 1 8] (currently amended) A system according to claim 1 wherein the system mav 

serialize the values of an object to a remote system and the receiving system may create a 

new instance of the object for pattern matching. 

[Claim 1 9] (original) Objects according to claims 16 to 1 8 are considered temporal by the 
rule engine if the object's original instance and nodes reside on a remote system. 
[Claim 20] (currently amended) A system according to claim 1 wherein the system defines 
three types of input channels: standard input, data distribution and node distribution. 
[Claim 21 ] (currently amended) A system according to claim 1 wherein the system defines 
a set of application interfaces and components to handle incoming data inout. events and 
requests for pattern matching. 

[Claim 22] (original) Input according to claim 21 Is defined as standard input channel. 
[Claim 23] (currently amended) A system according to claim 1 wherein the system defines 
a data distribution channel for sending and receiving remote data between rule engines. 
[Claim 24] (currently amended) A system according to claim 1 wherein the system defines 
a pattern distribution channel for distributing RETE nodes and patterns . 
[Claim 25] (currently amended) A system according to claim 1 wherein the system 
considers an object as temporal if it was sent through the data distribution channels. 
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[Claim 26] (currently amended) Temporal objects according to claim 1 9 and 25 are used 
by the engine to perform pattern matching and those objccsts arc may be discarded 
immediately after the pattern matching process Is complete. 

[Claim 27] (currently amended) A system according to claim 1 wherein the system w ill 
route the index results of claim 26 back to the originating system using the data 
distribution channel. 

[Claim 28] (currently amended) A system according to claim 1 wherein the system w ill 
update the index of the join and terminal nodes as a result of pattern matching according to 
claim 26. 

[Claim 29] (currently amended) A system according to claim 1 wherein the system 
processes the outputs of the rule and produces a set of results, if the original event began 
locally. 

[Claim 30] (currently amended) A system according to claim 1 wherein the system uses 
messaging system to route new events to a cluster of rule engines. 
[Claim 3 1 ] (original) A messaging system according to claim 30 filters new messages and 
routes them to the correct engine. 

[Claim 32] (currently amended) A system according to claim 1 wherein the system uses 
messaging system to route the final results as defined by a rule to the recipient. 
[Claim 33] (currently amended) A system according to claim 1 wherein the system 
contains a component responsible for communicating with the messaging system. 
[Claim 34] (original) A messaging component according to claim 33 is responsible for 
processing inbound events and generating new messages for outbound publication. 
[Claim 35] (currently amended) A system according to claim 1 wherein the system prefers 
to process new data events asynchronously using a messaging system , but is not required 
to use asynchronous communication . 
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[Claim 36] (original) Distributed nodes according to claim 14 contain information about 
the originating engine, a timestamp of when the nodes were distributed and a priority 
attribute. 

[Claim 37] (original) The priority attribute according to claim 36 may be used by the 
engine to remove the nodes, if all local object instances have been removed from the 
working memory. 

[Claim 38] (currently amended) Distributed nodes according to claim 14 will not be 
removed from the local pattern matching network, if data for those patterns is still being 
used, either in active rules about to fire or in remote rule engine instances procedura l 
attachm e nt ca ll s . 

[Claim 39] (currently amended) A system according to claim 1 wherein the svstem may 
forward node distribution messages, if the system does not have sufficient resources. 
[Claim 40] (original) A forward message according to claim 1 9 must retain the location of 
the originating engine and add the current engine's unique runtime name to a list of 
recipients. 

[Claim 41 ] (currently amended) A system according to claim 1 wherein the svstem w ill 
notify the producer of the node distribution message of success or failure. 
[Claim 42] (original) Distributed nodes according to claim 14 may be distributed at 
deployment time. 

[Claim 43] (currently amended) A system according to claim 1 wherein the svstem w ill set 
an attribute of the input node to indicate that the pattern has been distributed. 
[Claim 44] (original) An input node according to claim 43 will maintain a list of the remote 
systems and the total number of data objects routed remotely. 

[Claim 45] (currently amended) A system according to claim 1 wherein the svstem may 
not attempt to distribute nodes that were distributed by another rule engine. Instead, it 
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should notify the originating engine it cannot receive additional data until resources are 
available. 

[Claim 46] (currently amended) A system according to claim 1 wherein the system may 
randomly select a remote engine to route data to, if the pattern is distributed to more than 
1 engine. 
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